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IN THE CLAIMS 

Please amend the claims as follows, substituting any amended claim(s) for the 
corresponding pending claim(s): 



1 1 . (Previously Presented) A method for routing data within a host device comprising: 

2 receiving a data block at a receiver of the host device; 

3 storing the data block in a receiver buffer of the host device, wherein storing the data 

4 block in the receiver buffer includes storing the data block in the receiver buffer at an old free 

5 linked list head addres s ; 

6 determining an input virtual channel corresponding to the data block; 

7 updating an input virtual channel linked list corresponding to the input virtual channel to 

8 include the data block; 

9 determining an output virtual channel for the data block; 

10 transferring the data block from the input virtual channel linked list of the receiver buffer 

11 to a destination within the host device via the output virtual channel, wherein transferring the 

12 data block from the input virtual channel linked list of the receiver buffer to a destination within 

13 the host device via the output virtual channel includes reading the data block from the receiver 

14 buffer at an old input virtual channel linked list head address; and 

15 updating the input virtual channel linked list to remove the data block. 

1 2. (Original) The method of claim 1, wherein determining an output virtual channel for the 

2 data block includes processing one or more of the input virtual channel, a header corresponding 

3 to the data block, a protocol corresponding to the data block, source identifier/address 

4 corresponding to the data block, and a destination identifier/address corresponding to the data 

5 block. 
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1 3. (Previously Presented) The method of claim 1, wherein: 

2 updating an input virtual channel linked list corresponding to the input virtual 

3 channel to include the data block includes: 

4 reading a new free linked list head address from the receiver buffer at an old free 

5 linked list head address; 

6 writing the new free linked list head address to a free linked list head register; 

7 writing the old free linked list head address to the receiver buffer at the old input 

8 virtual channel linked list tail address; and 

9 writing the old free linked list head address to an input virtual channel linked list 
10 tail register. 

1 4. (Previously Presented) The method of claim 1 , wherein: 

2 updating the input virtual channel linked list to remove the data block includes: 

3 reading a new input virtual channel linked list head address from the receiver 

4 buffer at the old input virtual channel linked list head address; 

5 writing the new input virtual channel linked list head address to an input virtual 

6 channel linked list head register; 

7 writing the old input virtual channel linked list head address to the receiver buffer 

8 at an old free linked list tail address; and 

9 writing the old input virtual channel linked list head address to a free linked list 
10 tail register. 

1 5. (Original) The method of claim 1, further comprising writing a data block to the receiver 

2 buffer and reading a data block from the receiver buffer in a single read/write cycle. 

1 6. (Original) The method of claim 1, further comprising anticipating the write of a data 



2 block to the receiver buffer in a subsequent read/write cycle by reading a new free linked list 

3 head address from the receiver buffer at an old free linked list head address in a current 

4 read/write cycle. 



3 



Appl. No. 10/675,745 

Response mailed September 11, 2009 

Reply to Office Action, mailed date June 11, 2009 



Docket No. BP3252 



1 7. (Original) The method of claim 1, further comprising in a common read/write cycle in 

2 which a first data block is read from the receiver buffer and a second data block is written to the 

3 receiver buffer: 

4 reading the first data block and a new input virtual channel head address from the 

5 receiver buffer at an old input virtual channel head address; 

6 writing the new input virtual channel head address to the input virtual channel head 

7 register; 

8 writing the second data block to the receiver buffer at the old input virtual channel head 

9 address; 

10 writing the old input virtual channel head address to an input virtual channel tail register; 

11 and 

12 writing the old input virtual channel head address to the receiver buffer at an old input 

13 virtual channel tail address. 

1 8. (Original) The method of claim 1, further comprising supporting a plurality of input 

2 virtual channel linked lists, wherein each input virtual channel linked list corresponds to a 

3 respective input virtual channel. 

1 9. (Original) The method of claim 1, further comprising supporting a free linked list that 

2 includes a plurality of vacant data blocks of the receiver buffer. 

1 10. (Original) The method of claim 1, further comprising maintaining a mapping indicating a 

2 relationship between a plurality of input virtual channels and a plurality of output virtual 

3 channels. 
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1 11. (Previously Presented) A method for routing data within a host device comprising: 

2 receiving a data block at a receiver of the host device, the data block received via an input 

3 virtual channel; 

4 storing the data block in a receiver buffer of the host device, wherein storing the data 

5 block in the receiver buffer includes storing the data block in the receiver buffer at an old free 

6 linked list head address; 

7 when the input virtual channel has identified therewith an output virtual channel updating 

8 an output virtual channel linked list corresponding to the output virtual channel to include the 

9 data block; and 

10 when the input virtual channel has not identified therewith an output virtual channel: 

1 1 updating an input virtual channel linked list corresponding to the input virtual channel to 

12 include the data block; 

13 processing the data block to determine an output virtual channel for the data block; 

14 updating an output virtual channel linked list corresponding to the output virtual channel 

15 to include the data block; and 

16 updating the input virtual channel linked list to remove the data block. 

1 12. (Previously Presented) The method of claim 11, further comprising: 

2 transferring the data block from the receiver buffer to a destination within the host device 

3 based upon a corresponding output virtual channel; and 

4 updating the output virtual channel linked list to remove the data block. 
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1 13. (Previously Presented) The method of claim 11, wherein: 

2 updating an input virtual channel linked list corresponding to the input virtual channel to 

3 include the data block comprises: 

4 reading a new free linked list head address from the receiver buffer at an old free 

5 linked list head address; 

6 writing the new free linked list head address to a free linked list head register; 

7 writing the old free linked list head address to the receiver buffer at the old input 

8 virtual channel linked list tail address; and 

9 writing the old free linked list head address to an input virtual channel linked list 
10 tail register. 

1 14. (Original) The method of claim 1 1 , further comprising writing a data block to the 

2 receiver buffer and reading a data block from the receiver buffer in a single read/write cycle. 

1 15. (Original) The method of claim 11, further comprising anticipating the write of a data 

2 block to the receiver buffer in a subsequent read/write cycle by reading a new free linked list 

3 head address from the receiver buffer at an old free linked list head address in a current 

4 read/write cycle. 
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1 16. (Original) The method of claim 11, further comprising in a common read/write cycle in 

2 which a first data block is read from the receiver buffer and a second data block is written to the 

3 receiver buffer: 

4 reading the first data block and a new output virtual channel head address from the 

5 receiver buffer at the old output virtual channel head address; 

6 writing the new output virtual channel head address to the output virtual channel head 

7 register; 

8 writing the second data block to the receiver buffer at the old output virtual channel head 

9 address; 

10 writing the old output virtual channel head address to an output virtual channel tail 

1 1 register; and 

12 writing the old output virtual channel head address to the receiver buffer at the old output 

13 virtual channel head address. 

1 17. (Original) The method of claim 11, further comprising supporting a plurality of input 

2 virtual channel linked lists, wherein each input virtual channel linked list corresponds to a 

3 respective input virtual channel. 

1 18. (Original) The method of claim 11, further comprising supporting a plurality of output 

2 virtual channel linked lists, wherein each output virtual channel linked list corresponds to a 

3 respective output virtual channel. 

1 19. (Original) The method of claim 11, further comprising supporting a free linked list that 

2 includes a plurality of vacant data blocks of the input buffer. 
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1 20. (Original) A received data processing and storage system comprising: 

2 an input that receives data blocks corresponding to a plurality of input virtual channels; 

3 a routing module that determines an output virtual channel for data blocks based upon 

4 their respective input virtual channels; 

5 a receiver buffer operable to instantiate an input virtual channel linked list for storing data 

6 blocks on an input virtual channel basis and to instantiate a free list that identifies free data 

7 locations; 

8 a linked list control module operably coupled to the receiver buffer; 

9 input virtual channel linked list registers operably coupled to the linked list control 

10 module; and 

1 1 free linked list registers operably coupled to the linked list control module. 

1 21. (Original) The received data processing and storage system of claim 20, further 

2 comprising an output that transmits data blocks corresponding to a plurality of input virtual 

3 channels. 

1 22. (Original) The received data processing and storage system of claim 20, wherein: 

2 the receiver buffer is further operable to instantiate an output virtual channel linked list 

3 for storing data blocks on an output virtual channel basis; and 

4 the system further comprises output virtual channel linked list registers operably coupled 

5 to the linked list control module and an input virtual channel to output virtual channel map. 

1 23. (Original) The received data processing and storage system of claim 20, wherein the 

2 receiver buffer comprises: 

3 a pointer memory; and 

4 a data memory, wherein a single address addresses corresponding locations of the pointer 

5 memory and of the data memory. 
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24. (Original) The received data processing and storage system of claim 23, wherein the 
receiver buffer further comprises a packet status memory, wherein a single address addresses 
corresponding locations of the pointer memory, the data memory, and the packet status memory. 
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1 25. (Original) The received data processing and storage system of claim 23, further 

2 comprising a pointer memory read port, a pointer memory write port, a data memory read port, 

3 and a data memory write port, each of which can access the receiver buffer in a common 

4 read/write cycle. 

1 26. (Original) The received data processing and storage system of claim 25, wherein: 

2 a single pointer memory location can be read from and written to in a common read/write 

3 cycle; and 

4 a single data memory location can be read from and written to in a common read/write 

5 cycle. 

1 27. (Original) The received data processing and storage system of claim 20, wherein the 

2 receiver buffer comprises: 

3 a pointer memory; 

4 a data memory; 

5 a packet status memory; and 

6 wherein a single address addresses corresponding locations of the pointer memory, the 

7 data memory, and the packet status memory. 

1 28. (Original) The received data processing and storage system of claim 27, further 

2 comprising: 

3 a pointer memory read port; 

4 a pointer memory write port; 

5 a data memory read port; 

6 a data memory write port; 

7 a packet status memory read port; and 

8 a packet status memory write port. 
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1 29. (Original) The received data processing and storage system of claim 28, wherein: 

2 a single pointer memory location can be read from and written to in a common read/write 

3 cycle; 

4 a single data memory location can be read from and written to in a common read/write 

5 cycle; and 

6 a single packet status memory location can be read from and written to in a common 

7 read/write cycle. 
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